<template>
  <div>
    <p>场景 1：嵌套表格禁用某项（单选）</p>
    <br />
    <tiny-select
      v-model="value1"
      value-field="id"
      text-field="city"
      render-type="grid"
      :grid-op="gridOpRadio"
      :radio-config="radioConfig"
    ></tiny-select>
    <br /><br />
    <p>场景 2：嵌套表格禁用某项（多选）</p>
    <br />
    <tiny-select
      v-model="value2"
      value-field="id"
      multiple
      text-field="city"
      render-type="grid"
      :grid-op="gridOp"
      :select-config="selectConfig"
    ></tiny-select>
  </div>
</template>

<script setup>
import { ref } from 'vue'
import { TinySelectWrapper as TinySelect } from '@opentiny/vue'

const selectConfig = ref({
  checkMethod({ rowIndex }) {
    return rowIndex % 2 === 0
  }
})

const radioConfig = ref({
  checkMethod({ rowIndex }) {
    return rowIndex % 2 === 1
  }
})

const value1 = ref('')
const value2 = ref([])

const gridOpRadio = ref({
  data: [
    { id: '001', area: '华南区', province: '广东省', city: '广州市' },
    { id: '002', area: '华南区', province: '广东省', city: '深圳市' },
    { id: '003', area: '华南区', province: '广东省', city: '珠海市' },
    { id: '004', area: '华南区', province: '广东省', city: '佛山市' },
    { id: '005', area: '华南区', province: '广东省', city: '中山市' }
  ],
  columns: [
    { type: 'radio', title: '' },
    { field: 'area', title: '区域', width: 100 },
    { field: 'province', title: '省份', width: 50 },
    { field: 'city', title: '城市' }
  ]
})

const gridOp = ref({
  data: [
    { id: '001', area: '华南区', province: '广东省', city: '广州市' },
    { id: '002', area: '华南区', province: '广东省', city: '深圳市' },
    { id: '003', area: '华南区', province: '广东省', city: '珠海市' },
    { id: '004', area: '华南区', province: '广东省', city: '佛山市' },
    { id: '005', area: '华南区', province: '广东省', city: '中山市' }
  ],
  columns: [
    { type: 'selection', title: '' },
    { field: 'area', title: '区域', width: 100 },
    { field: 'province', title: '省份', width: 50 },
    { field: 'city', title: '城市' }
  ]
})
</script>

<style lang="less" scoped>
.tiny-select {
  width: 280px;
}
p {
  font-size: 14px;
  line-height: 1.5;
}
</style>
